Cerner Medications System API - Implementation Template
Setup guide
Please review the pre-requisite setup instructions for System Account and App setup in Cerner.
Importing Templates into Anypoint Studio
- In Studio, click the Exchange X icon in the upper left of the taskbar.
- Log in with your Anypoint Platform credentials.
- Search for the template.
- Click Open.
Running Templates in Anypoint Studio
After you import your template into Studio, follow these configuration steps to run it:
Common Configuration
- mule.env- sets the environment where the application is to be deployed. It should be configured in- config-<mule.env>.yamlfile. For a studio deployment, the recommended mule.env value is- local.
- mule.key- sets the encryption password to be used for encrypting secure properties. Update as needed.
- api.baseurl- sets the base url of the api. Replace/override as needed when deploying to any environment. It should be configured in- config-<mule.env>.yamlfile. Default value is- https://localhost:8082/api, when- mule.envis- local.
- api.autoDiscoveryIDshould be configured in- config-<mule.env>.yamlfile.
Cerner Configuration
- cerner.tokenurl- sets the token url for Cerner. It should be configured in- config-<mule.env>.yamlfile.
- cerner.baseurl- sets the base url for Cerner R4 requests. It should be configured in- config-<mule.env>.yamlfile.
- cerner.scopes- set the scopes for the OAuth request to Cerner Token Url. Update the scopes as required for the operations. It should be configured in- config-<mule.env>.yamlfile.
- cerner.clientId- sets the client id to be used for requests to Cerner Url. It should be configured in- config-<mule.env>.yamlfile.
- cerner.clientSecret- sets the client secret to be used for requests to Cerner Url. It should be encrypted and configured in- config-secured-<mule.env>.yamlfile.
Please refer to the attached link on how to secure the configuration properties.
HTTPS Configuration
- https.host— sets the service host interface. It should be configured in- config-<mule.env>.yamlfile. (Defaults to 0.0.0.0 for all interfaces).
- https.port— sets the HTTPS service port number. It should be configured in- config-<mule.env>.yamlfile. (Default 8082).
- TLS Configuration - Keystore properties setup:- keystore.alias- sets the alias to the keystore. It should be configured in- config-<mule.env>.yamlfile.
- keystore.path- sets the path to the key file. Key should be available in /src/main/resources/keystore. It should be configured in- config-<mule.env>.yamlfile.
- keystore.keypass— sets keystore keypass to support HTTPS operation. It should be encrypted and configured in- config-secured-<mule.env>.yamlfile.
- keystore.password— sets keystore password to support HTTPS operation. It should be encrypted and configured in- config-secured-<mule.env>.yamlfile.
 
Please refer to the attached link on how to generate the Keystore.
Run it
- Right-click the template project folder.
- Hover your mouse over Run as.
- Click Mule Application (configure).
- Inside the dialog, select Environment and set the variable mule.env to the appropriate value (e.g dev or local).
- Inside the dialog, select Environment and set the variable mule.key. Click Run.
Deployment instructions for CloudHub using provided scripts
Ensure the Maven profile CloudHub-HLS-DEV has been properly configured in yoursettings.xml file. Reference can be found by downloading the Accelerator Common Resources asset. Additional instructions are available in the Getting Started with MuleSoft Accelerators - Build Environment guide.
Update the config-dev.yaml properties appropriately and then use one of the following scripts to deploy application to CloudHub:
- packageDeploy.sh (Mac/Linux)
- packageDeploy.cmd (Windows)
Test it
- Use Advanced Rest Client or Postman to send a request over HTTPS. The template includes a postman collection in the src/test/resourcesfolder. Update the collection variable(s) after successful import.